/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

import Ember from 'ember';

export default Ember.Component.extend({

  process: null,
  processor: null,

  didInsertElement: Ember.observer("process.startEvent.time",
      "process.endEvent.time", "processor.timeWindow", function () {
    var processor = this.get("processor"),
        startPos = processor.timeToPositionPercent(this.get("process.startEvent.time")),
        endPos = processor.timeToPositionPercent(this.get("process.endEvent.time"));

    Ember.run.scheduleOnce('afterRender', this, function() {
      this.$(".process-line").css({
        left: startPos + "%",
        right: (100 - endPos) + "%",
        "background-color": this.get("process").getColor()
      });
    });
  }),

  sendMouseAction: function (name, mouseEvent) {
    this.sendAction(name, "process-line", this.get("process"), {
      mouseEvent: mouseEvent,
    });
  },

  mouseEnter: function (mouseEvent) {
    this.sendMouseAction("showTooltip", mouseEvent);
  },

  mouseLeave: function (mouseEvent) {
    this.sendMouseAction("hideTooltip", mouseEvent);
  },

  mouseUp: function (mouseEvent) {
    this.sendMouseAction("click", mouseEvent);
  }


});
